home *** CD-ROM | disk | FTP | other *** search
/ PC-Blue - MS DOS Public Domain Library / PC-Blue MS-DOS Public Domain Library - NYACC.iso / vol218 / printper.bas (.txt) < prev    next >
Encoding:
GW-BASIC  |  1986-11-30  |  7.2 KB  |  269 lines

  1. 100  REM PRINTPER Program.
  2. 110  REM Prints Detailed Personal Information
  3. 120  REM By:  Melvin O. Duke.  Last Updated 17 February 1986.
  4. 200  REM Screen Definitions
  5. 210  WIDTH "scrn:", 80
  6. 220  SCREEN S1,S2,S3,S4
  7. 600  REM Titles
  8. 610  TITLE$ = "Print the Persons "
  9. 611  IF DD.ORD$ = "no" THEN 613
  10. 612  TITLE$ = TITLE$ + "and Ordinances "
  11. 613  TITLE$ = TITLE$ + "File"
  12. 620  TITLE$ = TITLE$ + " ON DISPLAY"
  13. 700  REM Terminate if not called from the Menu
  14. 710  IF DD.MENU$ <> "" THEN 770
  15. 720  COLOR 7,0 : KEY ON : CLS : LOCATE 15,1
  16. 730  PRINT "Cannot run the"
  17. 740  PRINT TITLE$
  18. 750  PRINT "Program, unless selected from the MENU"
  19. 760  END
  20. 770  REM OK
  21. 1000  REM Produce the first screen
  22. 1010  KEY ON : CLS : KEY OFF
  23. 1020  REM Draw the outer double box
  24. 1030  R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 1300
  25. 1040  REM Find the title location
  26. 1050  TITLE.POS = 40 - INT(LEN(TITLE$)/2)
  27. 1060  REM Draw the title box
  28. 1070  R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 1500
  29. 1080  REM Print the title
  30. 1090  LOCATE 4,TITLE.POS : PRINT TITLE$
  31. 1100  LOCATE 5,40-INT(LEN(VERSION$)/2) :  PRINT VERSION$;
  32. 1230  REM Draw the Copyright box
  33. 1240  R1 = 19 : C1 = 21 : R2 = 22 : C2 = 59 : GOSUB 1300
  34. 1250  REM Print the Copyright
  35. 1260  LOCATE 20,40-INT(LEN(COPY1$)/2) :  PRINT COPY1$;
  36. 1270  LOCATE 21,40-INT(LEN(COPY2$)/2) :  PRINT COPY2$;
  37. 1280  GOTO 1700
  38. 1300  REM subroutine to print a double box
  39. 1310  COLOR P
  40. 1320  FOR I = R1 + 1 TO R2 - 1
  41. 1330   LOCATE I, C1 : PRINT CHR$(186);
  42. 1340   LOCATE I, C2 : PRINT CHR$(186);
  43. 1350  NEXT I
  44. 1360  FOR J = C1 + 1 TO C2 - 1
  45. 1370   LOCATE R1, J : PRINT CHR$(205);
  46. 1380   LOCATE R2, J : PRINT CHR$(205);
  47. 1390  NEXT J
  48. 1400   LOCATE R1, C1 : PRINT CHR$(201);
  49. 1410   LOCATE R1, C2 : PRINT CHR$(187);
  50. 1420   LOCATE R2, C1 : PRINT CHR$(200);
  51. 1430   LOCATE R2, C2 : PRINT CHR$(188);
  52. 1440  COLOR W
  53. 1450  RETURN
  54. 1500  REM subroutine to print a single box
  55. 1510  COLOR B
  56. 1520  FOR I = R1 + 1 TO R2 - 1
  57. 1530   LOCATE I, C1 : PRINT CHR$(179);
  58. 1540   LOCATE I, C2 : PRINT CHR$(179);
  59. 1550  NEXT I
  60. 1560  FOR J = C1 + 1 TO C2 - 1
  61. 1570   LOCATE R1, J : PRINT CHR$(196);
  62. 1580   LOCATE R2, J : PRINT CHR$(196);
  63. 1590  NEXT J
  64. 1600   LOCATE R1, C1 : PRINT CHR$(218);
  65. 1610   LOCATE R1, C2 : PRINT CHR$(191);
  66. 1620   LOCATE R2, C1 : PRINT CHR$(192);
  67. 1630   LOCATE R2, C2 : PRINT CHR$(217);
  68. 1640  COLOR W
  69. 1650  RETURN
  70. 1700  REM ask user to press a key to continue
  71. 1710  LOCATE 25,1
  72. 1720  PRINT "Have Data Diskette(s) in Place, then Press any key to continue.";
  73. 1730  K$ = INKEY$ : IF K$ = "" THEN 1730
  74. 1740  KEY ON : CLS : KEY OFF
  75. 2000  REM PRINTPER Program Starts Here.
  76. 2010  IF DD.ORD$ = "no" THEN 2050
  77. 2020  OPEN DD.ORD$+"ordfile" AS #2 LEN = 256
  78. 2030  FIELD 2,5ASO1$,11ASO2$,11ASO3$,11ASO4$,5ASO5$,5ASO6$,11ASO7$,11ASO8$,11ASO9$,11ASO10$,11ASO11$,5ASO12$,11ASO13$,11ASO14$,11ASO15$,11ASO16$,11ASO17$,11ASO18$,11ASO19$,11ASO20$,11ASO21$,11ASO22$,11ASO23$,26ASO24$
  79. 2040  REM
  80. 2050  OPEN DD.PERS$+"persfile" AS #1 LEN = 256
  81. 2060  FIELD 1, 5 AS F1$, 20 AS F2$, 30 AS F3$, 2 AS F4$, 5 AS F5$, 5 AS F6$, 5 AS F7$, 11 AS F8$, 18 AS F9$, 16 AS F10$, 16 AS F11$, 11 AS F12$, 18 AS F13$, 16 AS F14$, 16 AS F15$, 11 AS F16$, 18 AS F17$, 16 AS F18$, 16 AS F19$
  82. 2070  REM Read all records, and print the actual ones
  83. 2080  KEY ON : CLS : KEY OFF
  84. 2090  LOCATE 23,1
  85. 2100  INPUT "Enter the Record Number to be Printed (0 to quit) or 'all'";REPLY$
  86. 2110  IF LEFT$(REPLY$,1) = "a" OR LEFT$(REPLY$,1) = "A" THEN 2170
  87. 2120  IF REPLY$ = "0" THEN 3740
  88. 2130  I = VAL(REPLY$)
  89. 2140  IF I < 1 OR I > MAX.PER THEN KEY ON : CLS : KEY OFF : LOCATE 22,1 : PRINT "Number is out of range"; : GOTO 2090
  90. 2150  GOSUB 2200  'to print
  91. 2160  GOTO 2080
  92. 2170  FOR I = 1 TO MAX.PER
  93. 2180  GOSUB 2200
  94. 2190  GOTO 3730
  95. 2200  GET #1, I
  96. 2210  KEY ON : CLS : KEY OFF
  97. 2220  LOCATE 23,1 : PRINT "Processing Record #";I
  98. 2230  REM Extract information from the file for use
  99. 2240  T1 = CVS(F1$)
  100. 2250  IF T1 < 1 THEN 3720  'return
  101. 2260  REM Print a Title on Each Page
  102. 2270  LPRINT ,"Content of the Persons ";
  103. 2280  IF DD.ORD$ = "no" THEN 2300
  104. 2290  LPRINT "and Ordinances ";
  105. 2300  IF DD.ORD$ = "no" THEN LPRINT "File" ELSE LPRINT "Files"
  106. 2310  LPRINT ,DATE$, TIME$
  107. 2320  LPRINT
  108. 2330  T2$ = F2$
  109. 2340  T3$ = F3$
  110. 2350  FOR J = 1 TO LEN(F3$)-1
  111. 2360   IF RIGHT$(T3$,1)=" "THEN T3$ = LEFT$(T3$,LEN(T3$)-1) ELSE J = LEN(F3$)-1
  112. 2370  NEXT J
  113. 2380  T4$ = F4$
  114. 2390  IF LEFT$(T4$,1) = "M" THEN T4$ = "Male"
  115. 2400  IF LEFT$(T4$,1) = "F" THEN T4$ = "Female"
  116. 2410  T5 = CVS(F5$)
  117. 2420  T6 = CVS(F6$)
  118. 2430  T7 = CVS(F7$)
  119. 2440  T8$ = F8$
  120. 2450  T9$ = F9$
  121. 2460  T10$ = F10$
  122. 2470  T11$ = F11$
  123. 2480  T12$ = F12$
  124. 2490  T13$ = F13$
  125. 2500  T14$ = F14$
  126. 2510  T15$ = F15$
  127. 2520  T16$ = F16$
  128. 2530  T17$ = F17$
  129. 2540  T18$ = F18$
  130. 2550  T19$ = F19$
  131. 2560  IF DD.ORD$ = "no" THEN 2850
  132. 2570  REM Extract Ordinance Information
  133. 2580  GET #2, I
  134. 2590  U1 = CVS(O1$)
  135. 2600  REM bypass if no Ordinances Record Present
  136. 2610  IF U1 = 0 THEN GOSUB 3850 : GOTO 2850
  137. 2620  U2$ = O2$
  138. 2630  U3$ = O3$
  139. 2640  U4$ = O4$
  140. 2650  U5 = CVS(O5$)
  141. 2660  U6 = CVS(O6$)
  142. 2670  U7$ = O7$
  143. 2680  U8$ = O8$
  144. 2690  U9$ = O9$
  145. 2700  U10$ = O10$
  146. 2710  U11$ = O11$
  147. 2720  U12 = CVS(O12$)
  148. 2730  U13$ = O13$
  149. 2740  U14$ = O14$
  150. 2750  U15$ = O15$
  151. 2760  U16$ = O16$
  152. 2770  U17$ = O17$
  153. 2780  U18$ = O18$
  154. 2790  U19$ = O19$
  155. 2800  U20$ = O20$
  156. 2810  U21$ = O21$
  157. 2820  U22$ = O22$
  158. 2830  U23$ = O23$
  159. 2840  U24$ = O24$
  160. 2850  REM Print out of Personal Information
  161. 2860  LPRINT BOLD.ON$;
  162. 2870  LPRINT ,"Personal Information"
  163. 2880  LPRINT BOLD.OFF$;
  164. 2890  LPRINT
  165. 2900  LPRINT ,"Record-Number:",T1
  166. 2910  LPRINT ,"Surname:",,T2$
  167. 2920  LPRINT ,"Given-names:",,T3$
  168. 2930  LPRINT ,"Sex:",,T4$
  169. 2940  LPRINT ,"Code:",,T5
  170. 2950  LPRINT ,"Father's Record-number:",T6
  171. 2960  LPRINT ,"Father's Name: ",
  172. 2970  IF T6 = 0 THEN LPRINT : GOTO 3020
  173. 2980  GET #1, T6
  174. 2990  TMP$ = F2$ : GOSUB 3790 : TT2$ = TMP$
  175. 3000  TMP$ = F3$ : GOSUB 3790 : TT3$ = TMP$
  176. 3010  LPRINT LEFT$(TT3$ + " " + TT2$,33)
  177. 3020  LPRINT ,"Mother's Record-number:",T7
  178. 3030  LPRINT ,"Mother's Name: ",
  179. 3040  IF T7 = 0 THEN LPRINT : GOTO 3090
  180. 3050  GET #1, T7
  181. 3060  TMP$ = F2$ : GOSUB 3790 : TT2$ = TMP$
  182. 3070  TMP$ = F3$ : GOSUB 3790 : TT3$ = TMP$
  183. 3080  LPRINT LEFT$(TT3$ + " " + TT2$,33)
  184. 3090  LPRINT ,"Birth-date:",,T8$
  185. 3100  LPRINT ,"Birth-city:",,T9$
  186. 3110  LPRINT ,"Birth-county:",,T10$
  187. 3120  LPRINT ,"Birth-state:",,T11$
  188. 3130  LPRINT ,"Death-date:",,T12$
  189. 3140  LPRINT ,"Death-city:",,T13$
  190. 3150  LPRINT ,"Death-county:",,T14$
  191. 3160  LPRINT ,"Death-state:",,T15$
  192. 3170  LPRINT ,"Burial-date:",,T16$
  193. 3180  LPRINT ,"Burial-city:",,T17$
  194. 3190  LPRINT ,"Burial-county:",T18$
  195. 3200  LPRINT ,"Burial-state:",,T19$
  196. 3210  LPRINT : LPRINT : LPRINT
  197. 3220  IF DD.ORD$ = "no" THEN 3710
  198. 3230  LPRINT BOLD.ON$;
  199. 3240  LPRINT ,"Ordinance Information"
  200. 3250  LPRINT BOLD.OFF$;
  201. 3260  LPRINT
  202. 3270  REM Print the Ordinance Information
  203. 3280  LPRINT ,"Christening Date:",U2$
  204. 3290  LPRINT ,"Blessing Date:",U3$
  205. 3300  LPRINT ,"Sealed to Parents:",U4$
  206. 3310  LPRINT ,"Father's Record-Number:",U5
  207. 3320  LPRINT ,"Father's Name: ",
  208. 3330  IF U5 = 0 THEN LPRINT : GOTO 3380
  209. 3340  GET #1, U5
  210. 3350  TMP$ = F2$ : GOSUB 3790 : TT2$ = TMP$
  211. 3360  TMP$ = F3$ : GOSUB 3790 : TT3$ = TMP$
  212. 3370  LPRINT LEFT$(TT3$ + " " + TT2$,33)
  213. 3380  LPRINT ,"Mother's Record-Number:",U6
  214. 3390  LPRINT ,"Mother's Name: ",
  215. 3400  IF U6 = 0 THEN LPRINT : GOTO 3450
  216. 3410  GET #1, U6
  217. 3420  TMP$ = F2$ : GOSUB 3790 : TT2$ = TMP$
  218. 3430  TMP$ = F3$ : GOSUB 3790 : TT3$ = TMP$
  219. 3440  LPRINT LEFT$(TT3$ + " " + TT2$,33)
  220. 3450  LPRINT ,"Baptism Date:",,U7$
  221. 3460  LPRINT ,"Confirmation Date:",U8$
  222. 3470  LPRINT ,"Patriarchal Blessing:",U9$
  223. 3480  LPRINT ,"Endowment Date:",U10$
  224. 3490  IF LEFT$(T4$,1) = "M" THEN 3580
  225. 3500  LPRINT ,"Sealed to Husband Date:",U11$
  226. 3510  LPRINT ,"Husband's Record-Number:",U12
  227. 3520  LPRINT ,"Husband's Name: ",
  228. 3530  IF U12 = 0 THEN LPRINT : GOTO 3580
  229. 3540  GET #1, U12
  230. 3550  TMP$ = F2$ : GOSUB 3790 : TT2$ = TMP$
  231. 3560  TMP$ = F3$ : GOSUB 3790 : TT3$ = TMP$
  232. 3570  LPRINT LEFT$(TT3$ + " " + TT2$,33)
  233. 3580  IF LEFT$(T4$,1) <> "M" THEN 3700
  234. 3590  LPRINT ,"Aaronic Priesthood Date:",U13$
  235. 3600  LPRINT ,"Deacon Date:",,U14$
  236. 3610  LPRINT ,"Teacher Date:",,U15$
  237. 3620  LPRINT ,"Priest Date:",,U16$
  238. 3630  LPRINT ,"Melchizedek Priesthood:",U17$
  239. 3640  LPRINT ,"Elder Date:",,U18$
  240. 3650  LPRINT ,"Seventy Date:",,U19$
  241. 3660  LPRINT ,"High Priest Date:",U20$
  242. 3670  LPRINT ,"Bishop Date:",,U21$
  243. 3680  LPRINT ,"Patriarch Date:",U22$
  244. 3690  LPRINT ,"Apostle Date:",,U23$
  245. 3700  LPRINT ,"Occupation:",,U24$
  246. 3710  LPRINT FORM.FEED$;
  247. 3720  RETURN
  248. 3730  NEXT I
  249. 3740  CLOSE #1
  250. 3750  CLOSE #2
  251. 3760  KEY ON : CLS : KEY OFF : LOCATE 21,1
  252. 3770  PRINT "End of Program"
  253. 3780  RUN DD.MENU$+"menu"
  254. 3790  REM Right-trim routine
  255. 3800  TMP2$ = TMP$
  256. 3810  FOR TRM = 1 TO LEN(TMP$)-1
  257. 3820   IF RIGHT$(TMP$,1) = " " THEN TMP$ = LEFT$(TMP$,LEN(TMP$)-1) ELSE TRM = LEN(TMP2$)-1
  258. 3830  NEXT TRM
  259. 3840  RETURN
  260. 3850  REM Blank Ordinances if No Ord Record
  261. 3860  U2$  = "" : U3$  = "" : U4$  = ""
  262. 3870  U5   = 0  : U6   = 0  : U12  = 0
  263. 3880  U7$  = "" : U8$  = "" : U9$  = "" : U10$ = ""
  264. 3890  U11$ = "" : U13$ = "" : U14$ = "" : U15$ = ""
  265. 3900  U16$ = "" : U17$ = "" : U18$ = "" : U19$ = ""
  266. 3910  U20$ = "" : U21$ = "" : U22$ = "" : U23$ = ""
  267. 3920  U24$ = ""
  268. 3930  RETURN
  269.